﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using CBE.Model;
using Common.DataAccess;
using Microsoft.Data.Extensions;

namespace CBE.DataAccess
{
    public class ReporteDemandaPromocionesDataAccess : GenericReportDataAccess<ReporteDemandaPromocionesView, ReporteDemandaPromocionesCriteria, CBEEntities>
    {
        public override List<ReporteDemandaPromocionesView> ReadViewsByCriteria(ReporteDemandaPromocionesCriteria criteriaEntity)
        {
            var listOfVentas = ObjectContext.CreateStoreCommand("ReporteDemandaPromociones_PorRangoFechas", System.Data.CommandType.StoredProcedure,
                new System.Data.SqlClient.SqlParameter("@pFechaDesde", criteriaEntity.FechaDesde),
                new System.Data.SqlClient.SqlParameter("@pFechaHasta", criteriaEntity.FechaHasta))
                .Materialize<ReporteDemandaPromocionesView>(r => new ReporteDemandaPromocionesView
                {
                    ID = r.Field<Guid>("ID"),
                    Codigo = r.Field<String>("Codigo"),
                    Descripcion = r.Field<String>("Descripcion"),
                    FechaInicio = r.Field<DateTime>("FechaInicio"),
                    FechaFin = r.Field<DateTime>("FechaFin"),
                    Servicios = r.Field<String>("Servicios"),
                    CantidadUsoPromocion = r.Field<Int32>("CantidadUsoPromocion"),
                    ImporteBonificado = r.Field<Decimal>("ImporteBonificado"),
                    EsPromocionPublica = r.Field<String>("EsPromocionPublica")
                });

            return listOfVentas.ToList();
        }
    }
}
